草庐IT

mysql - DRY 和类似查询

全部标签

ruby-on-rails - ActiveRecord 查询 : where a field is not true

我想查找某个字段不正确的所有记录。用于此的有效AR语法是:Dog.where(:stray=>[false,nil])是否有更简洁的方式来查询“nottrue”?到处都必须迎合这种mysql的细微差别,这真的很糟糕。 最佳答案 命名作用域怎么样?scope:not_stray,where("strayISNULLORstray=false")然后使用:Dog.not_stray 关于ruby-on-rails-ActiveRecord查询:whereafieldisnottrue,我们在

ruby-on-rails - 什么是类似 Twitter 名称的正则表达式?

我已经编码了一段时间,但直到最近才需要正则表达式。我需要像Twitter一样做一个接受用户名的正则表达式。基本上,我想一次允许一个下划线。名称中可以有多个下划线,但不能是连续的字符。也允许使用字母数字字符。但是数字不能作为名字的开头。名称如_我的名字67我的名字67我的名字_my_67_name_有效但是94我的名字__我的名字我的名字我的名字无效。我玩过Rubular并想出几个正则表达式:/^[^0-9\s+](_?[a-z0-9]+_?)+$/i/^([a-z_?])+$/i我一直遇到的问题是这些匹配多个下划线。 最佳答案 已编

ruby - ruby 中类似界面的设计模式

我正在寻求有关设计模式的帮助。我非常习惯java中的接口(interface),我不知道如何在ruby中获得类似的机制。它需要的是一种具有方法的接口(interface),例如联系人。为了获得联系人,我需要调用api,这可能是google、linkedid或任何网络服务。所以我想使用一个为我提供联系人方法的界面,我不想知道任何关于提供商的信息。我的第一次尝试看起来像这样(伪代码):ModuleAbstractContactdefcontacts#dosomestuffwith@data@dataendendclassImplincludeAbstractContactdefbuild_

ruby-on-rails - 有没有类似 Ruby On Rails 的 Xampp?

我对ruby​​还是个新手,我正在学习它,我实际上在Windows上使用Xamppforphp,但我一直在寻找一个完整的包来安装RoR服务器,就像Xampp无需任何人工操作。有什么工具吗? 最佳答案 你可以试试RailsInstaller 关于ruby-on-rails-有没有类似RubyOnRails的Xampp?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/5335815/

ruby - 如何优化 ActiveRecord find_in_batches 查询?

我正在使用Rails4.0.0和Ruby2.0.0。我的Post(如在博客文章中)模型与用户相关联,该用户具有用户的user_name、first_name、last_name的组合。我想迁移数据,以便通过外键(即用户ID)将帖子关联到用户。我在posts表中有大约1100万条记录。我在Linux服务器上使用rake任务运行以下代码来迁移数据。然而,我的任务一直被服务器“杀死”,大概是由于rake任务,特别是下面的代码,消耗了太多内存。我发现将batch_size降低到20并将sleep(10)增加到sleep(60)允许任务运行更长的时间,在不被杀死的情况下总共更新更多的记录,但需要

ruby - Rails 3.2 中的 DRY Controller

在代码气候分析之后,我发现我的Controller并不像它可能的那样干燥。方法如下:defindex@animals=current_user.animals.valid_animals.search(params[:search],params[:page])respond_todo|format|format.html#index.html.erbformat.json{renderjson:@animals}endend在所有的controller中基本都是一样的。基本上,scaffoldrails生成的代码在所有Controller中都是“相同的”。我怎样才能以真正好的方式使它

Ruby:是否有类似 Enumerable#drop 的东西返回枚举器而不是数组?

我有一些大的固定宽度文件,我需要删除标题行。跟踪迭代器似乎不是很惯用。#ThisiswhatIdonow.File.open(filename).each_line.with_indexdo|line,idx|ifidx>0...endend#ThisiswhatIwanttodobutIdon'tneeddrop(1)toslurp#thefileintoanarray.File.open(filename).drop(1).each_linedo{|line|...}Ruby的成语是什么? 最佳答案 这稍微更整洁:File.op

ruby - RethinkDB 单个请求中的多个查询

我正在尝试在对服务器的单个请求中执行多个RQL命令,但我可能会添加但没有成功。我试过r.union,但它只适用于序列。我真正想要的是:[r.db(..).table(..).get(id1).delete(),r.db(..).table(..).get(id2).delete(),r.db(..).table(..).insert(...)].run_all_at_once有什么办法吗?谢谢! 最佳答案 您还可以使用dor.do(r.table('test').insert({value1:"Hey"}),r.table('tes

Ruby:想要一个保留顺序的类似集合的对象

...或者一个防止重复条目的数组。Ruby中是否有某种对象:响应[]、[]=和默默地删除重复的条目是可枚举的(或至少支持find_all)保留条目插入的顺序?据我所知,数组支持点1、3和4;而Set支持1、2和3(但不支持4)。而SortedSet不会做,因为我的条目没有实现。 最佳答案 从Ruby1.9开始,内置的Hash对象保留了插入顺序。例如:h={}h[:z]=1h[:b]=2h[:a]=3h[:x]=0ph.keys#=>[:z,:b,:a,:x]h.delete:bph.keys#=>[:z,:a,:x]h[:b]=1p

ruby-on-rails - 如何在 Ubuntu 16.04 上安装 mysql2 [错误 : Error installing mysql2: ERROR: Failed to build gem native extension.]

这个问题在这里已经有了答案:Errorinstallingmysql2:Failedtobuildgemnativeextension(32个答案)关闭5年前。我不知道在ubuntu上安装mysql2:(sudogeminstallmysql2Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingmysql2:ERROR:Failedtobuildgemnativeextension.currentdirectory:/var/lib/gems/2.3.0/gems/mysql2-0.4.4/ext/my